<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../../vue.js"></script>
</head>

<body>
    <pre>
        计算属性和方法的区别
            1、计算属性 会基于 依赖 进行缓存 ，但是方法不会进行缓存
            2、计算属性在调用时不需要加括号， 但是方法在调用时 需要加（）
            3、计算属性一般直接写在差值表达式中， 而方法一般是通过事件来触发
    </pre>
    <div class="box">
        <div>{{reverseString}}</div>
        <div>{{reverseString}}</div>
        <div>{{reverseString1()}}</div>
        <div>{{reverseString1()}}</div>
        <div>{{age1}}</div>
    </div>
    <script>
        var vm = new Vue({
            el: '.box',
            data: {
                msg: '我爱你',
                age: 17
            },
            methods: {
                reverseString1() {
                    console.log(1) // 打印两次
                    return this.msg.split('').reverse().join('')
                },
            },
            computed: {
                reverseString() {
                    console.log(2) //打印一次
                    return this.msg.split('').reverse().join('')
                },
                age1() {
                    return this.age >= 18 ? '我成年了' : '我还是个孩子啊'
                }
            }
        })
    </script>
</body>

</html>